# This Page Is Inserted by IFW Operations and is not a part of the Official Record

### **BEST AVAILABLE IMAGES**

Defective images within this document are accurate representations of the original documents submitted by the applicant.

Defects in the images may include (but are not limited to):

- BLACK BORDERS
- TEXT CUT OFF AT TOP, BOTTOM OR SIDES
- FADED TEXT
- ILLEGIBLE TEXT
- SKEWED/SLANTED IMAGES
- COLORED PHOTOS
- BLACK OR VERY BLACK AND WHITE DARK PHOTOS
- GRAY SCALE DOCUMENTS

## IMAGES ARE BEST AVAILABLE COPY.

As rescanning documents will not correct images, please do not report the images to the Image Problems Mailbox.

THIS PAGE BLANK (USPTO)

PCT/EP99/07631

# BUNDESREPUBLIK DEUTSCHLAND 09/807522

PRIORITY DOCUMENT
SUBMITTED OR TRANSMITTED IN
COMPLIANCE WITH
RULE 17.1(a) OR (b)



Bescheinigung

ESU

EP39 176318

Die Océ Printing Systems GmbH in Poing/Deutschland hat eine Patentanmeldung unter der Bezeichnung :

"Elektronische Steuereinrichtung mit einem parallelen Datenbus und Verfahren zum Betreiben der Steuereinrichtung"

am 12. Oktober 1998 beim Deutschen Patent- und Markenamt eingereicht.

Die angehefteten Stücke sind eine richtige und genaue Wiedergabe der ursprünglichen Unterlagen dieser Patentanmeldung.

Die Anmeldung hat im Deutschen Patent- und Markenamt vorläufig das Symbol G 06 F 13/28 der Internationalen Patentklassifikation erhalten.

München, den 16. November 1999

**Deutsches Patent- und Markenamt** 

Der Präsident

Im Auftrag

Weihmayr

Aktenzeichen: <u>198 46 913.6</u>





20

#### Zusammenfassung

Die Erfindung betrifft eine elektronische Steuereinrichtung mit : "

10 einem parallelen Datenbus und mehreren mit dem Datenbus verbunde
nen Baugruppen. Die Baugruppen weisen jeweils einen Prozessor und eine Speichereinrichtung auf und sind mittels eines Bus
Controllers mit dem Datenbus verbunden. Die Daten werden zwischen einer Sender-Baugruppe und einer Empfänger-Baugruppe mittels

Nachrichten (Messages) übertragen. Der Datenbus entspricht im wesentlichen dem MULTIBUS II.

Die Erfindung zeichnet sich dadurch aus, daß der Bus-Controller der Sender-Baugruppe so ausgebildet ist, daß er ohne Inanspruchnahme des Prozessors der Sender-Baugruppe auf eine Anforderungs-Nachricht der Empfänger-Baugruppe in der Speichereinrichtung der Sender-Baugruppe gespeicherte Daten liest und an die Empfänger-Baugruppe übersendet.

Hierdurch wird zum einem der Prozessor der Sender-Baugruppe (I/O-Odul) entlastet und zum anderen die Kommunikation zwischen der ender-Baugruppe und der Empfänger-Baugruppe (Rastermodul) beim Verhandeln bzw. Festlegen des Datentransfers wesentlich verringert und auf eine einzige Anforderungs-Nachricht reduziert. Diese elektronische Steuerungseinrichtung ist vorzugsweise für einen Steuereinrichtung zum Ansteuern eines Hochleistungsdruckers ausgebildet.

(Fig. 4)

ZUSAMMENFASSUNG



Darf nicht geändert werden

Die Erfindung betrifft eine Steuereinrichtung mit einem parallelen Datenbus und ein Verfahren zum Betreiben der Steuereinrichtung.



5

10

20

25

30

35

1:

In "Das Druckbuch - Technik und Technologie der Hochleistungsdrucker von Océ Printing Systems GmbH - Drucktechnologien" Ausgabe 3c, Mai 1998, ISBN 3-00-001019-X ist eine als "SRA Controller" (SRA: Skalierbare Raster Architektur) bezeichnete Steuereinrichtung zum Ansteuern eines Hochleistungsdruckers beschrieben.

Der Aufbau dieser bekannten Steuereinrichtung ist schematisch in Fig. 1 gezeigt. Eine solche Steuereinrichtung 1 weist ein I/O-Modul 2, ein oder mehrere Rastermodule 3 und ein Serialiser-Modul 4 auf. Die einzelnen Module 2 bis 4 sind über einen parallelen Datenbus 5 miteinander verbunden. Die Rastermodule 3 und das Serialiser-Modul 4 sind über einen weiteren Pixel-Bus 6 miteinander verbunden. An das Serialiser-Modul 4 ist ein Hochleistungsdrucker 7 angeschlossen.

Das I/O-Modul 2 empfängt die Druckinformationen von einer Computereinrichtung, die ein Großrechnersystem oder auch ein Rechnernetzwerk sein kann. Die Druckinformation wird von dem I/O-Modul 2 an die Rastermodule 3 und das Serialiser-Modul 4 weitergeleitet, wobei die Rastermodule 3 die Druckbildinformationen empfangen und zu einem von dem Hochleistungsdrucker 7 verarbeitbaren Druckbild-

datenstrom umsetzen. Diese Druckbilddatenströme werden von den Rastermodulen 3 über den Pixel-Bus 6 an das Serialiser-Modul 4..... übertragen, das die Datenströme in einer vorbestimmten Folge aufz.... reiht und an den Hochleistungsdrucker 7 weiterleitet.

Der Datenbus ist z.B. ein Multibus II (Multibus ist eine eingentragene Marke der Intel Corp.). Der Multibus II ist ein synchronisierter Bus, der in IEEE Standard for a High-Performance Synchronous 32-Bit Bus: MULTIBUS II, The Institute of Electrical and Electronics Engineers, Inc., 345 East 47th Street, NY 10017, USA; 1988 festgelegt ist. Im nachfolgenden wird der "MULTIBUS II" vereinfacht als "Multibus" bezeichnet.

Die Module 2 bis 4 der Steuereinrichtung 1 sind jeweils mit einem Prozessor versehen. Eine Interprozessor-Kommunikation erfolgt bei auf dem Multibus basierenden Systemen durch einen Nachrichtenaustausch (Message-Transfer), wobei zur Übertragung von Daten Nachrichten mit Datenpaketen mit einer vorbestimmten Länge übermittelt werden.

20.

25

Beim Multibus gibt es zwei Arten dieser Nachrichten, nämlich sogenannte unangeforderte Nachrichten (unsolicited messages) und angeforderte Nachrichten (solicited messages). Die unangeforderten Nachrichten können als "intelligente Interrupts" betrachtet werden, wobei bis zu 255 Interruptquellen (die Anzahl gültiger Adressen) eine unangeforderte Nachricht aussenden können. Mit einer unangeforderten Nachricht können 28 Byte Statusinformationen übertragen werden.

Die Eigenschaften einer unangeforderten Nachricht sind, daß deren Ankunft vom Empfänger nicht vorhergesehen werden kann, sie eine begrenzte Länge und eine begrenzte Übertragungszeit aufweisen.

Angeforderte Nachrichten sind Nachrichten, die zum Übertragen von Datenpaketen dienen, wobei zunächst mittels unangeforderter Nachrichten (buffer request message, buffer grant message und buffer

reject message) die Übertragungsmodalitäten (Übertragungsrate, Datenmenge, ...) verhandelt werden.

Ein Datentransfer vom I/O-Modul 2 zu den Rastermodulen 3 über den 5 Datenbus 5 ist in einem Flußdiagramm in Fig. 2 gezeigt. Hierbei sind die Aktionen, die am I/O-Modul 2 stattfinden, auf der linken Seite und die Aktionen, die am Rastermodul 3 ausgeführt werden, auf der rechten Seite dargestellt.

Im Schritt S1 schickt das I/O-Modul 2 an ein Rastermodul 3 eine Nachricht, daß Daten vorhanden sind. Diese Nachricht wird von dem Prozessor des I/O-Moduls erzeugt. Hierauf schickt das Rastermodul, falls es Daten benötigt, im Schritt S2 eine entsprechende Nachricht. Diese Nachricht wird vom Prozessor des Rastermoduls 2 ausgelöst. Hat das I/O-Modul 2 diese Nachricht empfangen, programmiert der Prozessor einen DMA-Controller des I/O-Moduls zum Senden der gewünschten Daten an das Raster-Modul und schickt eine buffer-request-Nachricht an das Raster-Modul (Schritt S3). Kann das Raster-Modul diese Daten aufnehmen, programmiert deren Prozessor einen DMA-Controller zum Empfangen der Daten und sendet eine buffer-grant-Nachricht an das I/O-Modul (Schritt S4).

Mit dem Empfang der buffer-grant-Nachricht durch das I/O-Modul sind die "Verhandlungen" abgeschlossen und das I/O-Modul sendet eine ein Datenpaket enthaltende Daten-Nachricht an das Rastermo-dul (Schritt S5). Eine solche Daten-Nachricht wird so oft übertragen, bis alle Daten an das Raster-Modul übertragen worden sind, wobei dies in einem Schritt S6 geprüft wird.

30 Sind alle Daten an das Raster-Modul gesendet worden, dann ist der Datentransfer beendet (S7).

Die Schritte S2 bis S6 bilden eine angeforderte Nachricht (gestrichelter Rahmen), wobei die Verhandlung (S2 bis S4) mittels der die Daten angefordert werden, mit unangeforderten Nachrichten ausgeführt wird. Die einzelnen Nachrichten der Schritte S2 bis S4 werden jeweils von den Prozessoren der Module 2, 3 erzeugt.

Der Erfindung liegt die Aufgabe zugrunde, eine Steuereinrichtung. zu schaffen, die einen parallelen Datenbus und mehrere jeweils mit einem Prozessor versehene Baugruppen aufweist, die über den Datenbus kommunizieren können, so weiterzubilden, daß ein großer. Datenstrom schneller und effektiver verarbeitet werden kann. Eine weitere Aufgabe der Erfindung liegt in der Schaffung eines Verfahrens zum Betreiben einer solchen Steuereinrichtung, mit dem einfach und effektiv ein großer Datenstrom in der Steuereinrichtung bewältigt werden kann.

Die Aufgabe wird durch eine Vorrichtung mit den Merkmalen des Anspruchs spruchs 1 und durch ein Verfahren mit den Merkmalen des Anspruchs 6 gelöst. Vorteilhafte Ausgestaltungen der Erfindung sind in den Unteransprüchen angegeben.

10

20

2.5

30

35

Die erfindungsgemäße elektronische Steuereinrichtung ist mit einem parallelen Datenbus und mehreren mit dem Datenbus verbundener Baugruppen versehen, die jeweils einen Prozessor und eine Speichereinrichtung aufweisen und mittels eines Bus-Controllers mit dem Datenbus verbunden sind, wobei Daten zwischen einer Sender-Baugruppe und einer Empfänger-Baugruppe mittels Nachrichten übertragen werden. Die Erfindung zeichnet sich dadurch aus, daß der Bus-Controller der Sender-Baugruppe so ausgebildet ist, daß er ohne Inanspruchnahme des Prozessors der Sender-Baugruppe auf eine Anforderungs-Nachricht der Empfänger-Baugruppe in der Speichereinrichtung der Sender-Baugruppe gespeicherte Daten liest und an die Empfänger-Baugruppe übersendet. Die Empfänger-Baugruppe löst somit durch ihre Anforderungs-Nachricht bei der Sender-Baugruppe eine automatische Übertragung der Daten aus. Dies führt zu einer wesentlichen Entlastung der Sender-Baugruppe, da die Daten mittels eines DMA-Controllers direkt wesentlich schneller und effektiver ausgelesen werden können und der Prozessor nicht lange durch eine solche Datenübertragung belegt ist. Zudem wird die eingangs beschriebene "Verhandlung", die beim herkömmlichen Multibus drei Nachrichtenübermittlungen umfaßt (siehe Fig. 2) auf die Übermittlung einer einzigen Anforderungs-Nachricht reduziert,

wodurch eine weitere Vereinfachung und Beschleunigung des Übertragungsvorganges erzielt wird.

Das im Anspruch 6 angegebene Verfahren zum Betreiben einer solchen elektronischen Steuereinrichtung zeichnet sich dadurch aus daß die Empfänger-Baugruppe durch Senden der Anforderungs-Nachricht an die Sender-Baugruppe einen Datentransfer einleitet, und der Bus-Controller der Sender-Baugruppe ohne Inanspruchnahme des Prozessors der Sender-Baugruppe auf die Anforderungs-Nachricht in der Speichereinrichtung der Sender-Baugruppe gespeit cherte Daten ausliest und an die Empfänger-Baugruppe übersendet. Hierdurch kann ein großer Datenstrom von der Sender-Baugruppe zur Empfänger-Baugruppe schnell und effektiv übertragen werden, so daß die Steuereinrichtung einen großen Datenstrom bewältigen kann.

Bei einer bevorzugten Ausführungsform der Erfindung werden die zum Programmieren eines auf der Sender-Baugruppe angeordneten DMA-Contoller notwendigen Daten mittels der AnforderungsNachricht von der Empfänger-Baugruppe zur Sender-Baugruppe übermittelt. Die Empfänger-Baugruppe steuert somit mit der Anforderungs-Nachricht die Datenübertragung von der Sender-Baugruppe.

Mit dem erfindungsgemäßen Verfahren können die einzelnen Empfänger-Baugruppen die von ihnen gewünschten Daten unabhängig und gleichzeitig von der Sender-Baugruppe abrufen. Durch die automatische Abarbeitung der Anforderungs-Nachrichten in der Sender-Baugruppe kann diese die Daten sehr schnell zur Verfügung stellen. Die Vereinfachung des Übertragungsprotokolls bewirkt eine weitere Beschleunigung des Übertragungsvorganges.

Die Erfindung wird nachfolgend anhand eines in den Zeichnungen dargestellten Ausführungsbeispieles näher erläutert. Es zeigen schematisch:

25

30

4

- 5 Figur 2 ein Flußdiagramm eines Datentransfers nach einem vom Multibus bekannten Übertragungsverfahren,

drucker in einem Blockschaltbild,

- Figur 3 zwei über einen Datenbus verbundene Baugruppen,
- 10 Figur 4 den erfindungsgemäßen Datentransfer in einem Flußdia-
- Figur 5 den Aufbau einer Anforderungs-Nachricht in einem Blockschaltbild,

25

30

- Figur 6 den Aufbau einer Daten-Nachricht in einem Blockschaltbild, und
- Figur 7 den Aufbau eines Eintrages in einer an der Sender20 Baugruppe vorgesehenen Puffers in einem Blockschaltbild.

Die Erfindung wird anhand eines Ausführungsbeispieles einer elektronischen Steuereinrichtung 1 zum Ansteuern eines Hochleistungsdruckers erläutert, die den gleichen Aufbau wie die in Fig. 1 dargestellte, bekannte Steuereinrichtung aufweist und mit einem I/O-Modul 2, einem oder mehreren Rastermodulen 3 und einem Serialiser-Modul 4 versehen ist. Die einzelnen Module 2 bis 4 sind über einen parallelen Datenbus 5 miteinander verbunden. Die Rastermodule 3 und das Serialiser-Modul 4 sind über einen weiteren Pixel-Bus 6 miteinander verbunden. An das Serialiser-Modul 4 ist der Hochleistungsdrucker 7 angeschlossen.

Der Datenbus 5 ist eine Weiterentwicklung des Multibusses und ist zu diesem im wesentlichen kompatibel.

Die Module 2 bis 4 stellen jeweils eine mit dem Datenbus 5 verbundene Baugruppe 8 dar. Zwei solche Baugruppe 8, nämlich das I/O-Modul 2 und das Rastermodul 4 sind schematisch in Fig. 3 gezeigt.

· 5

10

20

25

30

35

Die Baugruppen 8 weisen jeweils einen Bus-Controller 9 auf, die mit einem internen, in den Bus-Controller 9 integrierten DMAController 10 versehen sind. Die Baugruppen besitzen jeweils einen Prozessor 11 und Speichereinrichtungen 12, die mittels eines internen Rechnerbusses 13 miteinander und mit dem Bus-Controller internen Rechnerbusses 13 miteinander und mit dem Bus-Controller internen sind. Die Baugruppen 8 weisen weitere Elemente auf, wie z.B. Bausteine und Leitungen für weitere Schnittstellen und dergleichen, die jedoch zur Vereinfachung der Darstellung in Fig.

Nachfolgend wird anhand von dem in Fig. 4 gezeigten Flußdiagramm der erfindungsgemäße automatische angeforderte Nachrichtentransfer erläutert. Hierbei sind die Aktionen, die am I/O-Modul 2 stattfinden, wiederum auf der linken Seite und die Aktionen, die am Rastermodul 3 ausgeführt werden, auf der rechten Seite dargestellt.

Während des Schritts S1 schickt das I/O-Modul 2 an ein Rastermodul 3 eine Nachricht, daß Daten vorhanden sind. Diese Nachricht wird von dem Prozessor des I/O-Moduls erzeugt und entspricht dem Schritt S1 gemäß dem in Fig. 2 gezeigten bekannten Verfahren.

Hierauf prüft das Rastermodul 3 in einem Schritt S8, ob es die vom I/O-Modul 2 angebotenen Daten benötigt und ob genügend Speicherplatz zur Aufnahme der Daten vorhanden ist. Diese Prüfung erfolgt durch den Prozessor 11 des Rastermoduls 3.

Sind diese Daten nicht vorhanden, programmiert der Prozessor 11 in einem Schritt S9 den DMA-Controller 10 im Bus-Controller 9 für den Empfang eines Datenpakets und schreibt eine Data-Request-Nachricht in den Bus-Controller 9. Die Data-Request-Nachricht enthält die Adresse der Daten im Speicher des I/O-Moduls 2, die

Anzahl der Datenbytes, die übertragen werden sollen, und einen sogenannten Duty-Cycle für das Senden der angeforderten Nachrichten. Mit dem Duty-Cycle wird festgelegt, in welchem Abstand angesischen. Mit dem Duty-Cycle wird festgelegt, in welchem Abstand angesischen Enderte Nachrichten über den Datenbus 5 gesendet werden. Darüber hinaus können in dieser Data-Request-Nachricht noch weitere Daten enthalten sein, die den jeweiligen Datentransfer näher bestimmen Der Aufbau dieser Data-Request-Nachricht ist in Fig. 5 gezeigt.

Diese Data-Request-Nachricht wird während des Schrittes S10 vom Bus-Controller 9 des Rastermoduls 3 an das I/O-Modul 2 über den

Datenbus 5 gesandt.

5

10

20

25

30

35

Nach Maßgabe der in der Data-Request-Nachricht enthaltenen Daten (Adresse der Daten im Speicher des I/O-Moduls, Anzahl der Datenbytes, Duty-Cycle, usw.) programmiert der Bus-Controller 9 des I/O-Moduls 2 seinen DMA-Controller 10 mit der Adresse und der Anzahl der zu übertragenden Bytes einer Daten-Nachricht (Schritt S11).

Die Struktur einer solchen Daten-Nachricht ist in Fig. 6 gezeigt. Eine Daten-Nachricht weist eine Source-Adresse und eine Destination-Adresse auf, wobei hierfür die Belegung der Data-Request-Nachricht gilt, so daß die Source-Adresse die Adresse der Empfänger-Baugruppe und die Destination-Adresse die Adresse der Sender-Baugruppe ist. Es sind zwei Typen von Daten-Nachrichten vorgesehen, nämlich der Typ 3CH und der Typ 3DH, deren Bedeutung unten näher erläutert wird. Mit der in Fig. 6 gezeigten Daten-Nachricht kann ein Datenpaket mit 32 Bytes (Byte 0 bis Byte 31) übertragen werden.

Zum Senden der in Fig. 6 gezeigten Daten-Nachricht startet der Bus-Controller im Schritt S12 den DMA-Controller 10 und packt die vom DMA-Controller 10 an den Bus-Controller 9 übermittelten Daten in ein Datenpaket. Das Datenpakete wird mittels einer Daten-

Nachricht über den Datenbus 5 vom I/O-Modul 2 zum Rastermodul 3 übertragen.

Im Schritt S13 wird geprüft, ob bereits alle Daten übertragen sind. Müssen weitere Daten übertragen werden, so geht der Programmablauf auf den Schritt S12 zurück, wodurch die nächste Daten-Nachricht übertragen wird. Dieser Vorgang wird so oft wieder holt, bis alle Daten paketweise vom I/O-Modul an das Rastermodul übertragen worden sind. Die hierbei verwendeten Daten-Nachrichten sind alle, bis auf die letzte Daten-Nachricht, vom Typ 3CH. Die hetzte Daten-Nachricht ist vom Typ 3DH. Mit der Übertragung aller Datenpakete ist der Datentransfer beendet (Schritt S14). Am Rastermodul 3 wird durch den Empfang der Daten-Nachricht vom Typ 3DH ein Interrupt ausgelöst, der dem Prozessor des Rastermoduls 3 anzeigt, daß der angeforderte Datentransfer beendet ist. Eine Meldung an den Prozessor des I/O-Moduls 2 erfolgt nur, wenn bei der Übertragung der Daten ein Fehler aufgetreten ist.

10

20

35

Die Schritte S8 bis S14 bilden den automatischen angeforderten Nachrichtentransfer (gestrichelter Rahmen). Dieser automatisch angeforderte Nachrichtentransfer umfaßt lediglich eine unangeforderte Nachricht, nämlich die Data-Request-Nachricht des Schrittes S10, und die angeforderten Daten-Nachrichten des Schrittes S14. Im Vergleich zu den angeforderten Nachrichten des bekannten Multibusses vermindert sich die Anzahl der unangeforderten Nachrichten von 3 auf 1. Hierdurch wird eine wesentliche Entlastung am Datenbus 5 erzielt.

Mit einem solchen automatischen angeforderten Nachrichtentransfer wird eine festgelegte Datenmenge von z.B. 4 KB übertragen.

Im Bus-Controller 9 des I/O-Moduls 2 ist ein Puffer vorgesehen, in dem die Parameter der automatisch angeforderten Nachrichtentransfere abgelegt werden können. Für jede Baugruppe 8, die als Empfänger-Baugruppe 3 fungieren kann, ist in diesem Puffer ein Eintrag vorgesehen. Im vorliegenden Ausführungsbeispiel weist der

Puffer 21 Einträge auf. Die in den Einträgen enthaltenen Parameter sind (Fig. 7)

- Source- und Destination-Adresse für den automatischen angeforderten Nachrichtentransfer,
- 2. Duty-Cycle für die Datenpakete,
- 3. DMA-Adresse der Daten in der Speichereinrichtung, und
- 4. Anzahl der Datenbytes

5

35

- Der Bus-Controller 9 des I/O-Moduls kann beim Empfang einer Anforderungsnachricht prüfen, ob der dem die Anforderungs-Nachricht
  sendenden Rastermodul 3 zugeordnete Eintrag des Puffers bereits
  mit einem Datentransfer kennzeichnenden Daten beschrieben ist.
  Falls im Eintrag bereits die Daten eines anderen automatisch angeforderten Nachrichtentransfers enthalten sind, kann eine Fehlermeldung ausgegeben und die Anforderungs-Nachricht zurückgewiesen, um zu verhindern, daß gleichzeitig zwei Nachrichtentransfers
  mit demselben Rastermodul eingeleitet werden.
- Der Bus-Controller 9 sorgt dafür, daß die Anforderungs-Nachrichten in der Reihenfolge ihres Eintreffens bearbeitet werden. Dies stellt sicher, daß jedes Rastermodul an die Reihe kommt.
- Die Anforderungs-Nachricht wird bei einem belegten Eintrag im Puffer oder bei einem belegten Eingangspuffer, in dem die eingehenden Nachrichten zwischengespeichert werden, mit der Fehlermeldung NACK abgewiesen. Die Anforderungs-Nachricht wird daraufhin solange wiederholt, bis sie entweder abgearbeitet werden kann oder die im Protokoll festgelegte Anzahl von Wiederholungen erreicht ist. Wenn die Daten-Nachrichten nicht vom Rastermodul 3 empfangen werden können, wird auch der Fehler NACK ausgegeben und sie werden solange wiederholt, bis sie aufgenommen werden können oder die festgelegte Anzahl von Wiederholungen erreicht ist.

Hat ein Rastermodul einen automatischen angeforderten Nachrichtentransfer angestoßen und sendet es während seines eigenen

5

20

30

Ein interner Puffer des Rastermoduls 3 für den Empfang der Daten-Nachrichten läuft voll. Weitere Daten-Nachrichten werden daher vom Rastermodul abgewiesen. Der Bus-Controller des I/O-Moduls wiederholt eine abgewiesene Daten-Nachricht noch max. 127 mal und stellt dann von sich aus den Datentransfer ein. Der Bus-Controller 9 des I/O-Moduls meldet daraufhin den Sachverhalt an seinen Prozessor weiter.

Zusätzlich läuft am Rastermodul ein interner Fail-Safe-Counter ab, der durch den Empfang einer Daten-Nachricht jedesmal auf seinen Startwert gesetzt wird. Der Ablauf des Counters wird dem Prozessor des Rastermoduls mitgeteilt, der daraufhin eine vom Multibus bekanntes Error-Recovery ausführt.

Bei einer bevorzugten Ausführungsform der Erfindung kann, um den obigen Ablauf auf der Seite des Rastermoduls zu beschleunigen (der Fail-Safe-Counter läuft in ca. 2 sec ab), der Prozessor des Rastermoduls bereits auf den DMA-Fehler reagieren, indem er den DMA-Empfangskanal des Transfers stoppt und über eine unangeforderte Nachricht an das I/O-Modul das Ende des Transfers mitteilt. Das Stoppen erfolgt beim I/O-Modul durch ein von dem Bus-

35 Controller ausgegebenen Lösch-Befehl zum Löschen des entsprechenden DMA-Empfangskanals.

Tritt ein DMA-Fehler beim I/O-Modul auf, wird wie bei einem Fehler am Rastermodul der DMA-Kanal von der internen Ablaufsteuerung gestoppt und es werden die entsprechenden Statusbits gesetzt. Zu- sätzlich wird eine unaufgeforderte Nachricht an das Rastermodul gesendet, damit dieses den Empfang der Daten-Nachricht stoppt.

Aufgrund dieser Nachricht gibt der Prozessor des Rastermoduls eis nen Stop-Befehl an den DMA-Controller und einen Lösch-Befehl an den Empfangskanal des automatisch angeforderten Nachrichtentransfers. Reagiert der Prozessor des I/O-Moduls nicht auf den DMA-Fehler, so läuft der bereits oben erwähnte Fail-Safe-Counter auf dem Rastermodul ab. Der Prozessor des Rastermoduls muß daraufhin eine unangeforderte Nachricht an das I/O-Modul senden, damit der Transfer auch vom I/O-Modul beendet wird.

5

10

20

25

Der bereits erwähnte Fail-Safe-Counter des Rastermoduls ist für den Empfang der Daten-Nachrichten vorgesehen, der jedesmal nach dem Empfang einer Daten-Nachricht des Typs 3CH neu gestartet wird. Er läuft ab, wenn innerhalb der eingestellten Zeit keine weitere Daten-Nachricht empfangen wird. In diesem Fall stoppt der Prozessor des Rastermoduls den DMA-Kanal im Bus-Controller und der Empfangskanal des automatisch angeforderten Nachrichtentransfers wird gelöscht. Zusätzlich wird an das I/O-Modul eine unangeforderte Nachricht gesandt, damit das I/O-Modul den automatischen angeforderten Nachrichtentransfer beenden kann. Hierbei ist ein Stop-Befehl für den DMA-Kanal des I/O-Moduls nicht notwendig, da dies von der internen Ablaufsteuerung des Bus-Controllers vorgenommen wird.

Ein laufender automatischer angeforderter Nachrichtentransfer

kann am Rastermodul mit einem Lösch-Befehl an den entsprechenden Empfangskanal abgebrochen werden. Der Befehl wirkt sich sofort aus. Alle danach eintreffenden Daten-Nachrichten werden vom Bus-Controller mit einer vom Multibus bekannten Fehlermeldung "Transfer-Not-Understood" abgewiesen. Die Beendigung des Empfangskanals des DMA-Controllers muß ebenfalls vom Prozessor ausgeführt werden.

- 5 a) Es ist ein Fehler am Datenbus aufgetreten. Als Fehler kommen in Betracht:
  - o Die Wiederholungsrate für eine Daten-Nachricht hat den Ma-°° ximalwert erreicht.
  - Bei der Übertragung der Daten-Nachricht trat ein Bus-Fehler, Bus-Timeout oder ein Agent-Error auf.
  - b) Es ist ein Fehler bei der DMA-Übertragung aufgetreten. Folgende Fehler kommen in Betracht:
    - Parity-Fehler

10

30

- Page-Miss-Fehler
- Fatal Error bei einem Transfer über den internen Rechner-Bus (PCI-Bus).
- c) Der Prozessor bricht den laufenden automatischen angeforderten Nachrichtentransfer durch ein Kommando ab.

In den Fällen a) und b) wird der automatische angeforderte Nachrichtentransfer aufgrund des Fehlers von der internen Steuerung des Bus-Controllers abgebrochen. Die interne Steuerung meldet die Fehlerursache durch Setzen eines ASOMERR-Bits in einem Nachrichten-Status-Register. Ist ein korrespondierender Interrupt in einem Nachrichten-Steuer-Register freigegeben, so wird zusätzlich ein Interrupt erzeugt. Der Prozessor des I/O-Moduls kann durch das Auslesen eines dem automatischen angeforderten Nachrichtentransfer zugeordnetem ASOM-Status-Register die Fehlerursache bestimmen. Bevor erneut ein automatischer angeforderter Nachrichtentransfer aufgenommen werden kann, muß der Prozessor des I/O-Moduls einen entsprechenden Befehl (ASOMGO) absetzen.

Der Prozessor kann einen laufenden automatischen angeforderten Nachrichtentransfer zu jedem Zeitpunkt abbrechen (siehe c). Je

nach dem verwendeten Befehl wird der automatische angeforderte Nachrichtentransfer noch zu Ende geführt oder sofort unterbrochen. Im letzteren Fall ist zu berücksichtigen, daß das Rastermodies dul auf das weitere Eintreffen von Daten-Nachrichten wartet. Es wird daher bei einer Unterbrechung eines automatisch angeforderten Nachrichtentransfers eine entsprechende Nachricht vom I/O-Modul an das Rastermodul übersandt.

Zur Protokollierung des automatischen angeforderten Nachrichten-10 transfers können am I/O-Modul folgende Optionen eingerichtet sein:



2. Im Bus-Controller ist ein Register vorgesehen, das die Nachrichten-ID der den automatischen angeforderten Nachrichtentransfer anfordernden Baugruppe enthält. Dieses Register wird zu Beginn des Transfers auf die Nachrichten-ID gesetzt und am Ende wieder zurückgesetzt. Das Register kann vom Prozessor jederzeit ausgelesen werden.

20

30

35

Die Erfindung ist oben anhand einer Steuereinrichtung zum Aufbereiten von Druckdaten für einen Hochleistungsdrucker beschrieben worden. Die erfindungsgemäße Steuereinrichtung ist gleichermaßen für jedwede Anwendung geeignet, bei welcher ein großer Datenstrom verarbeitet werden muß. Das I/O-Modul kann demnach allgemein als Sender-Baugruppe und das Rastermodul als Empfänger-Baugruppe betrachtet werden, wobei die Daten von der Sender-Baugruppe zur Empfänger-Baugruppe übertragen werden.

Bei dem oben beschriebenen Ausführungsbeispiel wird ein mit dem Multibus im wesentlichen kompatibler Datenbus verwendet. Die Erfindung ist jedoch nicht auf diese Art von Datenbus beschränkt, sondern kann für jeglichen parallelen Datenbus der für eine Multi-Prozessor-Architektur geeignet ist ausgelegt sein.



Bei den im Ausführungsbeispiel angegebenen Baugruppen ist ein in den Bus-Controller 9 integrierter DMA-Controller 10 vorgesehen. Im Rahmen der Erfindung kann der DMA-Controller 10 selbstverständlich auch außerhalb des Bus-Controllers 9 auf der Baugruppe angeordnet sein.

5

10

20

25

30

35

Die oben beschriebenen Daten-Nachrichten übertragen jeweils ein Datenpaket von 32 Bytes. Die Größe dieser Datenpakete kann je nach Bedarf variiert werden und z. B. 64 oder 128 Bytes umfassen. Die mit einem automatischen angeforderten Nachrichtentransfer übertragene Datenmenge kann auf eine beliebige Größe von z. B. 4KB, 8KB, 16KB oder dergleichen festgelegt werden.

Die Erfindung kann folgendermaßen kurz zusammengefaßt werden: Sie betrifft eine elektronische Steuereinrichtung mit einem parallelen Datenbus und mehreren mit dem Datenbus verbundenen Baugruppen. Die Baugruppen weisen jeweils einen Prozessor und eine Speichereinrichtung auf und sind mittels eines Bus-Controllers mit dem Datenbus verbunden. Die Daten werden zwischen einer Sender-Baugruppe und einer Empfänger-Baugruppe mittels Nachrichten (Messages) übertragen. Der Datenbus entspricht im wesentlichen dem MULTIBUS II.

Die Erfindung zeichnet sich dadurch aus, daß der Bus-Controller der Sender-Baugruppe so ausgebildet ist, daß er ohne Inanspruchnahme des Prozessors der Sender-Baugruppe auf eine Anforderungs-Nachricht der Empfänger-Baugruppe in der Speichereinrichtung der Sender-Baugruppe gespeicherte Daten liest und an die Empfänger-Baugruppe übersendet.

Hierdurch wird zum einem der Prozessor der Sender-Baugruppe (I/O-Modul) entlastet und zum anderen die Kommunikation zwischen der Sender-Baugruppe und der Empfänger-Baugruppe (Rastermodul) beim Verhandeln bzw. Festlegen des Datentransfers wesentlich verringert und auf eine einzige Anforderungs-Nachricht reduziert. Diese elektronische Steuerungseinrichtung ist vorzugsweise für einen

Steuereinrichtung zum Ansteuern eines Hochleistungsdruckers ausgebildet.





. 5

### Bezugszeichenliste



- Elektronische Steuereinrichtung
- 2. I/O-Modul 10
  - 3. Rastermodul
  - 4. Serialiser-Modul
  - 5. Datenbus
  - 6. Pixel-Bus
  - 7. Hochleistungsdrucker
  - 8. Baugruppe
  - 9. Bus-Controller
  - 10. DMA-Controller
  - 11. Prozessor
- 12. Speichereinrichtung 20
  - 13. Interner Rechnerbus







#### Ansprüche

.

5

1. Elektronische Steuereinrichtung mit
einem parallelen Datenbus (5) und
mehreren mit dem Datenbus (5) verbundener Baugruppen (8),
die jeweils einen Prozessor (11) und eine Speichereinrichtung (12) aufweisen und mittels eines Bus-Controllers (9)
mit dem Datenbus (5) verbunden sind, wobei Daten zwischen
einer Sender-Baugruppe und einer Empfänger-Baugruppe mittels
Nachrichten übertragen werden,
wobei der Bus-Controller (9) der Sender-Baugruppe so ausge-



10

wobei der Bus-Controller (9) der Sender-Baugruppe so ausgebildet ist, daß er ohne Inanspruchnahme des Prozessors (11) der Sender-Baugruppe auf eine Anforderungs-Nachricht der Empfänger-Baugruppe in der Speichereinrichtung (12) der Sender-Baugruppe gespeicherte Daten ausliest und an die Empfänger-Baugruppe übersendet.

20

2. Elektronische Steuereinrichtung nach Anspruch 1, dadurch gekennzeichnet, daß die Sender-Baugruppe einen DMA-Controller (10) zum Auslesen und zum Weiterleiten der in der Speichereinrichtung gespeicherten Daten aufweist.



- Elektronische Steuereinrichtung nach Anspruch 2, dadurch gekennzeichnet, daß der DMA-Controller (10) in den Bus-Controller (9) der
- 30 Sender-Baugruppe integriert ist.
  - Elektronische Steuereinrichtung nach einem der Ansprüche 1 bis 3,

dadurch gekennzeichnet,

daß der Datenbus (5) ein mit dem MULTIBUS II kompatibler Datenbus ist.

 Elektronische Steuereinrichtung nach einem der Ansprüche 1 bis 4,

dadurch gekennzeichnet,

5

10

20

30

35

daß die Empfänger-Baugruppe zur Überwachung des Nachrichtentransfers einen Fail-Safe-Counter aufweist, der beim Empfangen einer Daten-Nachricht neu gestartet wird.

6. Verfahren zum Betreiben einer elektronischen Steuereinrichtung, insbesondere nach einem der Ansprüche 1 bis 5, wobei consche Steuereinrichtung einen parallelen Daten- bus (5) und

mehrere mit dem Datenbus verbundene Baugruppen (2) aufweist, die jeweils mit einem Prozessor (11) und einer Speicherein- richtung (12) versehen sind und mittels eines Bus-Controllers (9) mit dem Datenbus (5) verbunden sind, wobei Daten zwischen einer Sender-Baugruppe und einer Empfänger-Baugruppe mittels Nachrichten übertragen werden, und die Empfänger-Baugruppe durch Senden einer Anforderungs-Nachricht an die Sender-Baugruppe einen Datentransfer ein-

der Bus-Controller der Sender-Baugruppe ohne Inanspruchnahme des Prozessors der Sender-Baugruppe auf die Anforderungs-Nachricht in der Speichereinrichtung (12) der Sender-Baugruppe gespeicherte Daten an die Empfänger-Baugruppe übersendet.

Verfahren nach Anspruch 6, dadurch gekennzeichnet,

leitet, und

daß nach dem Empfang einer Anforderungs-Nachricht der Bus-Controller (9) der Sender-Baugruppe mehrere jeweils ein Datenpaket enthaltende Daten-Nachrichten an die Empfänger-Baugruppe sendet.

8. Verfahren nach Anspruch 6 oder 7, dadurch gekennzeichnet, daß die Anforderungs-Nachricht die zum Programmieren eines an der Sender-Baugruppe angeordneten DMA-Controllers (10)

ŏ • • • • • •

für das Lesen und Senden der in der Speichereinrichtung (12) der Sender-Baugruppe gespeicherten Daten enthält.

9. Verfahren nach einem der Ansprüche 6 bis 8,

dadurch gekennzeichnet,

5

10

30

35

daß ein auf der Sender-Baugruppe angeordneter DMA-Controller (10) auf Grundlage der mit der Anforderungs-Nachricht über- mittelten Daten zum Lesen und Senden der in der Speicherein-richtung (12) der Sender-Baugruppe gespeicherten Daten vom Bus-Controller (9) programmiert wird.

10. Verfahren nach einem der Ansprüche 6 bis 9, dadurch gekennzeichnet,

daß mit dem Senden der Anforderungs-Nachricht ein auf der Empfänger-Baugruppe angeordneter DMA-Controller (10) zum Empfangen der Daten programmiert wird.

 Verfahren nach einem der Ansprüche 6 bis 10, dadurch gekennzeichnet,

daß die Daten mit mehreren Nachrichten, die jeweils ein Datenpaket enthalten, übertragen werden.

12. Verfahren nach einem der Ansprüche 6 bis 11, dadurch gekennzeichnet,

daß die Sender-Baugruppe einen Puffer aufweist, in dem für jede in der Steuereinrichtung vorhandene Baugruppe ein Eintrag vorgesehen ist, so daß während eines Datentransfers die den Datentransfer kennzeichnenden Parameter in den jeweiligen Eintrag eingeschrieben und gespeichert werden und nach Beendigung des Datentransfers gelöscht werden.

13. Verfahren nach Anspruch 12,
 dadurch gekennzeichnet,

daß beim Empfangen einer Anforderungs-Nachricht der Bus-Controller der Sender-Baugruppe prüft, ob der der Anforderungs-Nachricht sendenden Baugruppe zugeordnete Eintrag des Puffers bereits mit einen Datentransfer kennzeichnenden Da-

5 14. Steuereinrichtung zum Aufbereiten von Druckdaten für einen Hochleistungsdrucker,

#### gekennzeichnet durch

die Merkmale eines der Ansprüche 1 bis 5, wobei die Sender-Baugruppe ein I/O-Modul (2) bildet und mehrere Empfänger-Baugruppen vorgesehen sind, die jeweils ein Rastermodul (3) bilden.







10

1/4







FIG.2



3/4 I/O Modul Rastermodul S8> S9~ S10~ -S11 -S12 N -S13

FIG.4

~S14

4/4

000000

| D<3124>    | D<2316>                   | D<158>         | D<70>      |  |
|------------|---------------------------|----------------|------------|--|
| Reserved   | Type=02                   | Source_addr.   | Dest_addr. |  |
|            | data ad                   | dr. in I/O-CPU |            |  |
| Duty Cycle | Outy Cycle No. data bytes |                |            |  |

| Data    | Data    | Data    | Data    |
|---------|---------|---------|---------|
| byte 31 | byte 30 | byte 29 | byte 28 |

FIG.5

| D<3124> | D<2316> | D<158>       | D<70>        |
|---------|---------|--------------|--------------|
|         |         | Source_addr. | Dest_addr.   |
| ,       |         |              | Type=3CH,3DH |
| Data    | Data    | Data         | Data         |
| byte 3  | byte 2  | byte 1       | byte 0       |

| Data    | Data    | Data    | Data    |
|---------|---------|---------|---------|
| byte 31 | byte 30 | byte 29 | byte 28 |

FIG.6

|   | Byte 3    | Byte 2     | Byte 1       | Byte 0            |
|---|-----------|------------|--------------|-------------------|
| 1 |           | Duty Cycle | Source addr. | Destination addr. |
| 2 | DMA addr. |            |              |                   |
| 3 |           |            | Byte Count   |                   |

FIG.7



